# πιζηιζηιζηιζηιζηίζη 1

**При классификации программ** принято деление на прикладные или проблемные пользовательские и программы обеспечивающие функционирование работы комплекса систем в автономном режиме.

**Прикладные программы** — наборы долговременных библиотек програм, используемых для решения задач из конкретной области применения техники.

**Системные программы** используются для разработки новых программ, модификации уже существующих программ и выполнения программ автономным способом.

Управляющие системные программы, которые обеспечивают стабильность работы вычислительных систем, управляют процессами обработки, входят в ядро операционной системы, постоянно находятся в оперативной памяти, называются резидентными. А управляющие системные программы, которые загружаются в оперативную память перед их выполнением, называются транзитивными.

Системные обрабатывающие программы выполняются как специальное приложение и используются для разработки новых модификаций существующих программ.

**Архитектура ПК** включает в себя структурную организацию, то есть набор блоков и устройств, объединённых в вычислительную систему, и фунциональную организацию, обеспечивающую работу этих блоков.



**Архитектрура**  $\Pi K$  с точки зрения программиста — набор доступных блоков устройств.

Современные  $\Pi K$  имеют магистрально-модульный принцип построения, то есть к единой магистрали — системной шине подклбчены различные устройства.

**Шина** — набор линий, по которым информация передаётся от одного из источников к одному или нескольким приёмникам.

Существует три типа шин: адресная, данных и шина управления. По адресной шине информация передаётся от процессора, шина данных двунаправлена, то ест данные передаются от и к процессору, а шина урпавления включает в себя однонаправленные и двунаправленные каналы связи.

**Процессор** работает существенно быстрее внешних устройств, поэтому для организации параллельной работы процессора и внешних устройств в архитектуру ПК включёны: канал прямого доступа к памяти и информационные блоки (устройство управления внешними устройствами).

Чтобы синхронизировать работу внешних устройств и процессора используется система прерыывания. Если некоторому устройству требуется работа процессора, то это устройство посылает сигнал прерывания, он проходит через контролер прерывания, если условия выполнены, то контроллер посылает процессору прерывание, процессор обрабатывает его и возвращает устройству выполнение внешним устройством.

Существуют различные типы и классификации прерываний, они бывают внешние и внутренние, маскируемые и немаскируемые.

**Процессор с точки зрения** программиста — набор програмно доступных средств.

**X86** процессор при выключчённом питании устанавливается в реальный режим работы оперативной памяти и процессора, но реальная система переводит его в защищённый режим, обеспечивающий многозадачность и ресурсы для этих задач. Начиная с 386 процессора доступны 16 основных регистров, 11 регистров для работы с мультимедиа и сопроцессором и некоторые упрвляющие регистры.

**Регистры общего назначения** могут использоваться для хранения адресов, данных и команд. При работе с 16-ти разрядными данными их имена: AX, BX, CX, DX.

Для процессора минимальной единицей информации является байт, он может работать с регистрами: AL, AH, BL, BH, DL, DH. Эти регистры имеют их собственные имена, отражающие их назначение.

 ${\bf AX}-{\bf a}$ ккумулятор, в него записывается результат.

ВХ — базовый регистр, используется при адресации операндов по базе.

 ${f CX}-{f c}$ чётчик, автоматически используется для организации циклов, работы со стеком.

 $\mathbf{DX}$  — регистр данных.

## Регистры указателей и индексов

**Регистры индексов** используется для сложной адресации операндов, а регистры указателей SP, BP используются для работы со стеком.

Сегментные регистры. Рассматриваемый процессор может работать с оперативной памятью, как с 1 непрерывным массивом данных (flat), и памятью, разделённой на сегменты, в этом случае адрес байта состоит из 2-х частей: адрес начала сегмента и адрес внутри сегмента. И для получения адреса начала сегмента используются сегментные регистры DS, ES, FS, GS, CS, SS (16-ти разрядные).

**Операционная система** может размещать сегменты в любом месте оперативной памяти и даже временно на жёстком диске.

**Сегментных регистров 6**, но это не значит, что программа может использовать только 6 сегментов, программист может изменить содержимое сегментного регистра и попасть на другой адрес.

Сегментный регистр называют селектором, а с каждым селектором связан програмно недоступный регистр — дескриптор и в защищённом режиме имено в дескрипторе находится адрес начала сегмента, его размер и дополнительная информация.

В защищённом режиме размер сегмента ≤ 4Гб, а в реально режиме размер сегмента фиксирован и равен 64Кб и в сегментном решистре находятся старшие цифры 16-тиричного адреса начала сегмента. Адрес сегмента всегда кратен 16 и поэтому младшие цифры равны 0.

**4 сегментных регистра** DS, ES, FS, GS используются для хранения сегмента данных. CS содержит адрес кодового сегмента, SS — стекового сегмента.

**Сегмент стека** реализуется особым образом, адрес начала сегмента стека определяется автоматически ОПС и записывается в SS, а при добавлении элемента в стек, указатель на вершину стека SP уменьшается.

**При работе с памятью** в режиме flat программы хранятся в младших адресах, а стек в старших.

Стек используется для работы с подпрограммами, внего записываются фактические параметры, а если программист хочет хранить локальные параметры, тогда после загрузки в стек фактических параметров, содержимое регистра Sp записывается в BP и тогда обращение к фактическим параметрам реализуется по формуле BP+k, а к локальным BP-n, где n и k вычисляет сам программист, исходя из количества параметров и их размера.

 ${f IP}-{f c}$ чётчик команд указатель команд,в нём содержится смещение для следующей исполняемой команды.

**Регистр флагов FLAGS** (32-х разрядный), определяет состояние программы и процессора в каждый текущий момент времени.

| 3 | 1 | 1918 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5 | 4  | 3 | 2  | 1 | 0  |  |
|---|---|------|----|----|----|----|----|----|----|----|----|----|----|----|---|----|---|----|---|----|--|
|   |   | AC   | VM | RF |    | NF | IC | PI | OF | DF | IF | TF | SF | ZF |   | AF |   | PF |   | CF |  |

- CF перенос
- PF четность
- АF полуперенос
- ZF флаг нуля
- SF флаг знака
- TF флаг трассировки
- IF флаг прерывания
- DF флаг направления
- OF флаг переполнения

#### А в защищённом режиме добавляется ещё 5 флагов:

- АС флаг выравнивания операндов
- VM флаг виртуальных машин
- RF флаг маскирования прерывания
- NT флаг вложенной задачи
- IOPL уровень привилегий ввода/вывода.

#### **Регистры** 1, 5, 15, 19-31 не используются.

- ${f CF}-{f \phi}$ лаг переноса, утсанавливается в 1, если в результате выполнения операций произошёл перенос из старшего разряда.
- ${f PF}-{f \phi}$ лаг чётности, устанавливается в 1, если в младшем байте результата чётное число единиц.
- ${\bf AF}-{\bf \Phi}$ лаг полупереноса, устанавливается в 1, если при сложении произошёл перенос из третьего разряда в 4, а при вычитании из 4 в 3.
  - ${\bf ZF}-{\bf \phi}$ лаг нуля, устанавливается в 1, если результат равен 0.
  - ${\bf SF}-$ флаг знака, всегда равен знаку операнда (+  $\rightarrow$  1,0 или - $\rightarrow$  0).
- ${f TF}-{f \phi}$ тлаг трассировки, установленный в 1, переводит процессор в режим отладки.
- ${f IF}-{f \phi}$ лаг прерывания, установленный в 1, может маскировать какоето прерывание.
- **DF** флаг направления, определяет режим работы со строками, утсановленный в 1приводит к обработке строк от старшего адреса к младшему,

автоматически уменьшая содержимое регистров индексов на размер операндов, при утсановлении флага в 0, всё происходит наоборот.

 ${f OF}-{f \phi}$ лаг переполнения, устанавливается в 1, если результат не уместился.

## піSпіSпіSпіSпіSnіS

**Регистр** — набор из n устройств, способный хранить n-разрядное двоичное число.

Оперативная память состоит из байтов, байт состоит из 8 информациионых битов-разрядов, разряды с 0 по 3 называются цифровой частью байта, а с 4 по 7 зонной частью байта.

**Оперативная память** 32-х разрядного процессора может достигать  $4\Gamma$ 6 с адресами от 0 до  $2^{32-1}$ , что в 16-ричной системе счисления записывается от 00000000 до FFFFFFFF.

Байты могут объединяться в поля фиксированной и переменной длины. Адресом поля является адрес младшего байта, входящего в поле. Длина поля — количество байтов, входящих в поле. Поля фиксированной длины имеют собственные имена. Слово состоит из 2-х байтов, двойное слово из 4-х байтов. Поля переменной длины могут начинаться с любого байта.

**Процессор** может работать с непрерывной и сегментированной памятью. Если память сегментированна, то физический адрес байта состоит из 2-х частей: <сегмент>:<смещение>. И получается он по формуле: адрес начала сегмента + исполняемый адрес.

Смещение — исполняемый адрес, который формируется в зависимости от способа адресации операндов. В защищённом режиме может быть определено до 16083 сегметов, размером до  $4\Gamma$ б, процессор может обработать  $64\Gamma$ б виртуальной памяти.

**В реальном режиме** старшие 4 цифры адреса начала сегмента хранятся в сегментном регистре, адрес сегмента кратен 16, поэтому физический адрес получается смещением содержимого сегментного регистра на 4 разряда (двоичных) влево и прибавлением к нему исполняемого адреса.

**Физический адрес** следующей исполняемой команды получается: со-держимое регистра CS, смещённое на 4 разряда + IP. **Пример:** 

```
\Phi A = (CS) + (IP)
```

$$(IP) = C7D9_{16} = 1100\ 0111\ 1101\ 1001_2$$

 $<sup>(</sup>CS) = 7A15_{16} = 0111 \ 1010 \ 0001 \ 0101 \ 0000_2$ 

 $<sup>\</sup>Phi A = 86929_{16} = 1000\ 0110\ 1001\ 0010\ 1001_2$ 

## Форматы данных

Рассматриваемый нами процессор может обрабатывать целые числа без знака, целые числа со знаком, действительные числа с плавающей точкой, двоично-десятичные числа, символы, строки и указатели.

**Целое число без знака** может занимать байт, слово или двойное слово и изменяться от 0 до 255(байт), от 0 до 65535(слово) и от 0 до 4294967295(двойное слово).

**Целое число со знаком** может занимать байт, слово или двойное слово при этом старший разряд (7(байт), 15(слово) или 31(двойное слово)) отводится под знак числа (0 полодительной, 1 отрицательное), остальные разряды под цифры числа.

**Цифры со знаком** хранятся в дополнительном коде, дополнительный код положительного числа равен числу, а дополнительный код отрицательного числа может быть вычислен по формуле:  $10^n - |x|$ .

**Например**, представим в слове отрицательное число -AC7 ( $10^4 - AC7 = F539$ ).

**Дополнительный код** двоичного числа можно получить инверсией разрядов и прибавленем 1 к младшему разряду.

```
Например, -12 (в байте) (12 = 11110100)
```

**Вычитание в машине:** дополнительный код уменьшаемого прибавляется к вычитаемому, чтобы получить 65-42=23

- 1)  $65 = 0100\ 0001$
- $2) -42 = 1101 \ 0110$
- 3)  $65 + (-42) = 0100\ 0001 + 1101\ 0110$

**Число с плавающей точкой** может занимать 32 разряда, 64 разряда или 80 разрядов, и называется оно короткое вещественное, длинное вещественное и рабочее вещественное.

**Число с плавающей точкой** состоит из 3-х частей: знак (1 разряда), машиный порядок (8(если в общем число занимает32 разряда) или 11(64 разряда), или 15(80 разрядов) разрядов), мантисса (23(32 разряда) или 52(64 разряда), или 64(80 разрядов) разряда).

**Машинный порядок** не явным образом содержит в себе знак порядка, он изменяется от всех 0 до всех 1, в поле, которое ему определено, а с истинным порядком машинный порядок связан формулой:

$$\Pi_{\rm M} = \Pi_{\rm H} + 127_{10}(1023_{10}, 16383_{10})$$

Пример, 3060<sub>10</sub> представить в виде числа с плавающей точкой, занимающего 4 байта.

- 2) нормализуем число 0. BF4 $*10^{3}_{16}$
- 3) получим машинный порядок  $\Pi$ м =  $3_{16} + 7$ F $_{16} = 82_{16}$
- 4) запишем в разрядную сетку в 2-ичной системе счисления:

0 1000 0010 011 1111 0100 0000 0000 0000,

Или в 16-ричном виде: 413F4000<sub>16</sub>.

0100 0001 0 011 1111 0100 0000 0000 0000,

- 1) переведём в 16-ричное
- 2) нормализуем число
- 3) получаем машинный порядок
- 4) записываем в разрядную сетку, но хитрость заключается в том, что для экономии памяти старшая цифра мантиссы нормализованного числа не записывается в разрядную сетку (т.к. она равна 1(вроде всегда))

**Двоично-десятичные чисал** могут обрабатываться процессором как 8-ми разрядные в упакованном или неупакованном формате, а сопроцессором могут обрабатываться 80-ти разрядные в упакованном формате.

**Упакованный формат** предполагает хранение 2-х цифр в байте, а неупакованный только 1 цифры в цифровой части байта.

**Символьные данные** хранятся в ASCII коде, каждому символу отводится 1 байт памяти.

Строковые данные — это последовательности байтов, слов или двойных слов и указатели. Существует два типа указателей: длинный (48 разрядов селектор(16) + смещение(32)) и коротки (32 разряда).

### Форматы команд

**В машинном формате команда** — последовательность двоичных цифр, состоящая изменяется двух частей, определяющих код операции и адресную часть, то есть где хранятся данные и куда можно записать результат.

Рассматриваемый процессор может работать с безадресными командами, с одноадресными командами, двухадресными и трёхадресными командами. В памяти команда может занимать от 1 до 15 байтов в зависимости от кода операции количество операндов и места их расположения. А располагаться операнды могут непосредственно в команде, в регистрах или в оперативной памяти.

**Наибольшее количество коман**д двухадресных и тогда формат называют: R-R, M-M, R-M, M-R, R-D, M-D.

Существуют различные способы адресации операторов, а данные могут занимать байт, слово или двойное слово. И исполняемый адрес операнда зависит от способа адресации и может сотоять из трёх частей (база, индекс и смещение). Например, [BX][SI]М

### Способы адресации (в реальном режиме):

- 1) регистровая,
- 2) непосредственная,
- 3) прямая,
- 4) косвенно-регистровая,
- 5) по базе со смещением,
- 6) прямая с индексированием,
- 7) по базе с индексированием.

Машинный формат двухадресной команды, для которой один операн находится всегда в регистре, а второй – в регистре или памяти можно представить следующим образом:



<sup>&</sup>quot;disp H/disp L" – "старшая / младшая часть смещения.

Поля "код операции" и иногда "reg" определяют выполняемую операцию.

Поле "d" определяет место хранения первого операнда.

Поле "w" определяет с какими данными работают: с байтами, или словами. Если w=0, команда работает с байтами, w=1 - со словами.

reg" - определяет один операнд, хранимый в регистре.

Поля "mod", "disp H" и "disp L" определяют второй операнд, который может храниться в регистре или в памяти.

Если mod = 11, то второй операнд находится в регистре, он определяется полем "r/m", а "disp H/disp L" – отсутствует, команда будет занимать 2 байта в памяти, если mod <> 11, то второй операнд находится в памяти.

## Машинный формат двухадресной команды

Значение поля "mod" определяет как используется смещение:

то, disp — отсутствует mod  $\{0, \text{ disp } = \text{ disp } L - \text{ с распространением знака до 16 } 10$ , смещение состоит из disp H и disp L. Поля "reg" и "r/m" определяют регистры:



| reg/<br>r/m | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|
| w = 0       | AL  | CL  | DL  | BL  | AH  | СН  | DH  | вн  |
| w = 1       | AX  | CX  | DX  | BX  | SP  | BP  | SI  | DI  |

Физический адрес определяется так:



| r/m | ИА                 | ФА     |
|-----|--------------------|--------|
| 000 | (BX) + (SI) + disp | + (DS) |
| 001 | (BX) + (DI) + disp | + (DS) |
| 010 | (BP) + (SI) + disp | + (SS) |

Машинный формат двухадресной команды.

| r/m | ИА                 | ФА     |
|-----|--------------------|--------|
| 011 | (BP) + (DI) + disp | + (SS) |
| 100 | (SI) + disp        | + (DS) |
| 101 | (DI) + disp        | + (DS) |
| 110 | (BP) + disp        | + (SS) |
| 111 | (BX)+ disp         | + (DS) |

В ассемблере результат всегда посылается по адресу первого операнда.

## Адресация регистровая:

MOV AX, BX  $;(BX) \to AX$ 

Машинный формат: 1001 0011 1100 0011

"код операции" 100100

"d" = 
$$1$$

"mod" = 11

"reg" = 000

"r/m" = 011

Непосредственная адресация:

MOV AX,25;  $25 \rightarrow AX$ 

В ассемблере как и в языках высокого уровня есть именованные константы, они определяются с помощью EQU

**Конструкция:** <имя> <EQU> <значение>

Пример: (CONST EQU 34h)

Прямая адресация (адрес операнда прямо в команде записывается):

**MOV AX, ES: 0001** 

ES – регистр сегмента данных, 0001 – смещение внутри сегмента.

Содержимое двух байтов, начиная с адреса (ES) + 0001 пересылаются в АХ - $((ES) + 0001) \rightarrow AX$ .

Прямая адресация может быть записана с помощью символического имени, которому предварительно был присвоен некоторый адрес оперативной памяти, а присвоен может быть с помощью директивы.

DW - слово,

DD – двойное слово.

Если в сегменте ES содержится директива Var р DW, тогда по команде MOV AX, ES : Var\_p  $((ES) + Var p) \rightarrow AX$ .

Например, если команда имеет вид:  $\mathbf{N}$ IOV AX,  $\mathbf{Var}_{\mathbf{p}}$ ; ((DS) +  $\mathbf{Var}_{\mathbf{p}}$ )  $\rightarrow$  AX.

Косвенно-ресгистровая операция (в регистре содержится адрес операнда), в записи косвенно-регистровая от регистровой отличается записью регистра в квадратных скобках.

# MOV AX, [SI];

Могут использоваться регистры:

SI, DI, BX, BP, EAX. EBX, ECX, EDX, EBP, ESI, EDI.

Не могут использоваться: AX, CX, DX, SP, ESP.

Адресация по базе со смещением:

```
MOV AX, [BX]+2 ; ((DS) + (BX) + 2) →AX.

≡ MOV AX, [BX + 2] ;

≡ MOV AX, 2[BX] ;

MOV AX, [BP + 4] ; ((SS) + (BP) + 4) →AX.
```

ВР работает с сегментом стека.

#### Прямая с индексированием адресация:

$$MOV AX, MAS[SI]$$
;  $((DS) + (SI) + MAS) \rightarrow AX$ 

MAS – адрес в области памяти.

С помощью этой адресации работают с одномерными массивами или с полями структур, символическое имя определяет адрес начала массива или структуры, а содержимое SI используется для перехода от одного элемента массива к другому или от одного поля структуры к другому.

С двумерными массивами используется адресация по базе с индексированием.

$$MOV AX, Arr[BX][DI]$$
 ;  $((DS) + (BX) + (DI) + Arr) \rightarrow AX$ .

Символическое имя определяет адрес начала массива, с помощью индексного регистра реализуется переход от одного элемента к другому (в строке), а с помощью базового регистра от одной строке к другой.